# ⑩ 公 開 特 許 公 報 (A) 平1 - 147722

(i) Int Cl.

識別記号

庁内整理番号

每公開 平成1年(1989)6月9日

G 06 F 9/38

310

X - 7361 - 5B

審査請求 未請求 発明の数 1 (全5頁)

図発明の名称

情報処理装置のパイプライン処理方式

頤 昭62-308111 創特

**郊出** 願 昭62(1987)12月4日

切発 明 者

東京都港区芝5丁目33番1号 日本電気株式会社内

①出 願

彰 日本電気株式会社

東京都港区芝5丁目33番1号

弁理士 内 原 の代 理

墇

1. 発明の名称

情報処理装蔵のパイプライン処理方式

2. 特許請求の範囲

先行初仰をおこなう節報処理装置において、演 質実行のパイプライン処理をおこなわず、短いパ ィブライン動作をおこなう動作モードと、演算実 行のパイプライン処理をおこない、長いパイプラ イン動作をおこなう動作モードとの動作モード題 移をおこなう情報処理複数のパイプライン処理方 式。

3.発明の詳細な説明

(産業上の利用分野)

本発明はパイプライン処理をおこなう情報処理 装置に関し、特にパイプライン処理方式に関する。 (従来の技術)

従来、この紐の情報処理装置においては、浮動 小数点数命令、10進数命令の演算は演算が複雑 なため、演算の実行に複数サイクルかけて演算を おこなっていた。また、スーパーコンピュータや 大型計算機のなかには調算装置もパイプライン化 されているものもある。

(発明が解決しようとする問題点)

上述した従来の情報処理装置では、浮動小数点 数命令、10進数命令等は波算の実行に複数のサ イクルが必要なため、そのような命令を実行する とパイプラインに乱れが生じ命令実行のスループ ットが低下するという欠点があり、またスーパー コンピュータ等のように波算装置をパイプライン 化すると、連続した複算実行が可能になるため、 パイプラインに私れは生じずスループットも低下 しないが、反面演算処理サイクルがパイプライン 化されただけパイプラインが長くなるため、分岐 予測失敗の判定が遅れたり、アドレス態飾用レジ スタの確定待ちが長くなるという欠点がある。

(問題点を解決するための手段)

本発明の情報処理装置のパイプライン処理方式 は、勧尊実行のパイプライン処理をおこなわず、 類いパイプライン動作をおこなう動作モードと演 算実行のパイプライン処理をおこない、長いパイ

プライン動作をおこなう動作モードとの動作モー ド遊移をおこなう。

#### (作用)

浮動小数点命令の頻度が低く、分岐命令の頻度の高いオペレーティンクシステム等のシステムプログラム動作時は、非演算の高い分岐命令の処理時間を減らし、逆に浮動小数点命令の頻度が高く、分岐命令の頻度が低い科学技術計算プログラム等の動作時には演算パイプライン動作をおこなうことで、出現頻度の高い浮動小数点命令の処理時間を減らし、全体的なスループットを高めることができる。

#### (実施例)

次に、木発明の実施例について図面を参照して 説明する。

第1図は木発明のパイプライン処理方式が適用 された情報処理装設の一実施例のプロック図である。

木実施例は、命令制御装置1、記憶制御装置2、

ランドアドレスが生成され、記憶制御装置2に送 られ、アドレスレジスタ(VAR)21に保持さ れる。このオペランドアドレスはアドレス変換機 桁(TLB)22によりアドレス変換がおこなわ れ、キャッシュのアドレスアレイ(AA)22よ り歳出したディレクトリ情報とともにアドレスレ ジスタ(PAR)23に保持されデータアレイ (DA)24の終出しアドレスとして使用される。 これよりデータアレイ24よりオペランドが接出 され頻算装置3に送られる。一方、RXタイプ命 今の第1オペランドRRタイプ命令の第1.第2 オペランドが格納されているレジスタ番号はレジ スタ(IDR)18、デコード情報キュー(ID Q)19を軽て頒算装置3に送られ、レジスタ (EDR) 31に保持される。精算装置3では減 算実行に先立って命令制御装配 1 より送られたレ ジスタ番号をもとに汎用レジスタファイル(GR) 3 2 よりオペランドが読出される。読出されたレ ジスタ値のうちー方は第1オペランドとして演算 νジスタ (DARO, FDARO) 51. 41 €

消算装置3などで構成されている。

命令制御装置1は命令を記憶制御装置2より競出し、解読し、必要ならばアドレス計算により論理アドレスを求めてオペランドを記憶制節装置2より誘出し、操作コード、オペランド、操作情報等を被算装置3に転送する。演算装置3は命令制御装置1が設定した情報により演算を行ない、各種レジスクやステータスまたは記憶制御装置2を通じて主記憶の更新をおこなう。

命令制御装置1において、命令レジスタ(IR) 11のあるピットフィールドにより汎用レジスタ ファイル(CGR)13からレジスタの内容を読 出す。RXタイプの命令では、アドレス生成のた めに汎用レジスタファイル13によりインデック ス値、ベース値は命令で直接指定されるディスプ レースメント値とともにレジスタ(XR)15、 (BR)16、(DR)14にそれぞれ設定され る。これらのレジスタ14,15,16の値をも とにしてアドレス加算器(ADR)17よりオベ

設定される。もう一方のレジスタ値は記憶制御装 取 2 より直接あるいはデータパッファ ( D 🛭 ) 34を軽由して送られたオペランドとセレクタ (SEL)33で選択され第2オペランドとして **政算レジスタ(DAR1、FDAR1)52.** 42に設定される。胸口ユニット35、36はそ れぞれ2進基本演算、浮動小数点数演算をおこな う。演算ユニット(FAU)35は浮動小数点数 彼尊をおこなうが、浮動小数点数複算は彼箕の前 に得動小数点数の桁合せを、後に正規化をおこな う必要があり、演算に複数のサイクル必要である。 木実施例では被演算数の折合わせで1サイクル、 加減算で1サイクル、演算結果の正規化で1サイ クル必要であり、浮動小数点数の複算には3サイ クル必渡である。一方、約算ユニット(BAU) 3 6 は 2 進基本執算をおこなうが、 2 進数額 算は 浮動小数点数演算に比べて簡単であり、本実施例 では加波算1サイクルで終了する。なお、演算ユ ニット35は、レジスタ41,42.44.45. 47.49、桁合せ回路43、浮動小数点演算例

路(FALU)46、正規化回路48で構成され、 旗舞ユニット36は、レジスタ51,52,54. 55.56、論理演算回路 (ALU) 53で構成 されている。選択国路37はPSWに付加された 動作モードフラグに応答してレジスタ49.54. 56の出力を選択して出力する。ある命令により、 動作モードフラグに論理"1"を設定することで、 海算実行のパイプラインに処理がおこなわれるが、 演算ユニット35,36のパイプラインの長さを あわせるために2遊巷木演算の結果をもちまわる レジスタ (DCR. DDR) 55, 56 が使用さ れる。第2図(a) は木効作モードにおけるパイプ ラインのタイムチャートである。図において、D. A. P. C. L. E. N. S t e n e n f コード サイクル、アドレス生成サイクル、ページングサ イクル、キャッシュリードサイクル、桁合せサイ クル、演算サイクル、正規化サイクル、ストアサ イクルを示す。2進基本命令の旗群実行サイクル も浮動小数点命令に合せてやはり3サイクルかけ てパイプラインがスムーズに汲れるように制御さ

第2図(c)、(d) は2つのパイプラインモードにおける分岐命令の処理(分岐予測失政時)のタイムチャートである。分岐命令の分岐方向が決まるのは分岐命令の資前の命令の演算実行が終了したときである。分岐予測が成功したかどうかもこ

の時点で決まり、予測失敗時はそこからデコード サイクルを始めることになる。第2図(c) に演算 パイプラインモードでの分岐予測失数のタイムチ レートが示されている。同図で分岐命令の直前の 2 進基本命令の演算サイクルはNサイクルで終る が、このサイクルが終るまで分岐予測の成功/失 版がわからない。 したがって、予測失敗の場合、 分岐先命令の実行に5サイクルのおくれが生じて しまう。第2図(d) は動作モードフラグに論理値 "0"が設定された非演算パイプラインモードで の分岐予測失敗のタイムチャートが示である。同 数で分岐命令の直前の2進息本命令の演算処理サ イクルはEサイクルで称るが、このサイクルが終 ると分岐予測の成功/失敗が判る。したがって、 分岐予期失敗の場合、分岐先命令の実行に3サイ クルのおくれが生じるが、第2图(c)に示した場 合よりおくれが2サイクル少ない。

このように、微算パイプラインモード動作では 浮動小数点命令のように微算処理に複数サイクル 必要な命令の処理でも余分なサイクルを必要とし ないが、例えば分岐予測失敗によるおくれば大きい。一方、非領質パイプラインモード動作では浮動小数点命令のように演算処理に複数サイクル必要な命令の処理では演算処理サイクルにかかるだけパイプライン処理の乱れが生じるが、分岐予測失敗によるおくれば小さいという特徴がある。

本実施例では動作モードフラグが論理"1"のとき独算パイプラインモードになり論理値"0"のとき非数算パイプラインモードであったが、論理値の組合せは逆でも良い。

### (発明の効果)

以上説明したように本発明は、複算実行のパイプライン処理をおこなわず、短いパイプライン動作をおこなう動作モードと、複算実行のパイプライン動作をおこない良いパイプライン動作をおこなり動作モードとの動作モード雅移をおこなうことにより、浮動小数点命令の頻度が低く、分岐命令の頻度の高いオペレーティングシステム等のシステムプログラム動作時は、非演算パイプライン動作をおこなうことで出現頻度の高い分岐命令

処理時間を減らし、逆に浮動小数点命令の頻度が 高く、分岐命令の頻度が低い科学技術計算プログ ラム等の動作時には減算パイプライン動作をおこ なうことで、出現頻度の高い浮動小数点命令の処 理時間を減らし、全体的なスループットを高める 効果がある。

## 4. 図面の簡単な説明

第1 図は本発明のパイプライン処理方式が適用 された賃役処理装置の一実施例の観略プロック図、 第2 図は本実施例におけるタイムチャートである。

- 1…命令制御装置、
- 2 … 記憶制御装門、
- 3…湖郊装置、
- 35…浮動小数点数演算ユニット、
- 36…2進基本演算ユニット。

特許出願人 日本 億 気 株 式 会 社 代 應 人 弁理士 内 原 晋



第2図